/* 输入组样式 */
.inputGroup {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.label {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
}

.input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-border-primary);
  border-radius: var(--border-radius-md);
  background: var(--color-bg-secondary);
  color: var(--color-text-primary);
  font-size: 14px;
  font-family: inherit;
  transition: border-color var(--transition-fast);
  outline: none;
  box-sizing: border-box;
}

.input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px var(--color-primary-alpha);
}

.input:disabled {
  background: var(--color-bg-disabled);
  color: var(--color-text-disabled);
  cursor: not-allowed;
}

.input::placeholder {
  color: var(--color-text-tertiary);
}

.input.error {
  border-color: var(--color-error);
}

.input.error:focus {
  border-color: var(--color-error);
  box-shadow: 0 0 0 2px var(--color-error-alpha);
}

.errorText {
  font-size: 12px;
  color: var(--color-error);
  margin-top: 2px;
}

/* 移动端适配 */
@media (max-width: 768px) {
  .input {
    padding: 12px;
    font-size: 16px; /* 防止iOS缩放 */
  }
}
